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PATENT APPLICATION 
ATTORNEY DOCKET NO. SUN-P5012-RSH 



METHOD AND APPARATUS FOR 
FACILITATING USE OF A PRE-SHARED 
SECRET KEY WITH IDENTITY HIDING 

Inventor(s): Radia J. Perlman 



BACKGROUND 

Field of the Invention 

The present invention relates to encryption and computer security. More 
specifically, the present invention relates to a method and an apparatus for 
facilitating a key exchange protocol that operates with a pre-shared key and that 
hides the identities of entities involved in the key exchange. 

Related Art 

Recent advances in computer networks make it easier to access a computer 
system from a remote location. For example, "road warrior" with a laptop 
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computer can access a server at a central office in order to receive email or access 
files from the server. However, providing this ability can lead to security 
problems because an attacker may also be able to access the organization's 
computer systems. Furthermore, even if the attacker is not able to access the 
organization's computer systems, the attacker may be able to eavesdrop on 
communications between the remote user and the organization's computer 
systems. 

In order to guard against such attacks, an organization can install a 
"firewall" to filter all communications with an external network, and a remote 
user can be given a secret key that is known only to the remote user and the 
firewall. This secret key can then be used to encrypt subsequent communications 
between the remote user and the firewall. 

The remote user can then be required to authenticate itself to the firewall 
in order to gain access to protected computer systems within the firewall. This 
authentication can be accomplished by sending an identifier for the remote user to 
the firewall. In response to this identifier, the firewall sends a challenge to the 
remote user. The remote user encrypts this challenge using a pre-shared secret 
key that was previously agreed upon between the remote user and the firewall, and 
then sends the encrypted challenge to the firewall. The firewall can then decrypt 
the encrypted challenge using the same pre-shared secret key to verify that the 
remote user possesses the pre-shared secret key. All subsequent communications 
between the remote user and the firewall are then encrypted using the pre-shared 
secret key. However, note that this technique requires the remote user to send its 
identifier to the firewall in the clear. Hence, an attacker can intercept the 
identifier and can thereby determine the identity of the remote user. 

Another technique that can be used to establish a secure communication 
session between two computer systems involves an anonymous Diffie-Hellman 
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exchange. A Diffie-Hellman exchange allows two computer systems to agree on 
a secret shared key, even though they can only exchange messages in public. 
Referring the FIG. 2, a Diffie-Hellman exchange begins by allowing two parties 
"J" and "B" to pick random numbers S A and S B , respectively (steps 202 and 204). 
A then computes T A = g SA mod p, where p is a large prime number and g is 
number less than p with certain restrictions that are not important for a basic 
understanding of the method (step 206). Similarly, B computes T B = g SB mod p 
(step 208). Next, A and B exchange T A and T B (steps 210 and 212). A then 
computes the shared secret key as T b Sa mod p (step 214). B similarly computes 
the shared secret key as T A B mod p (step 216). Note that T B A - (g SA f B = g SASn = 
(g SA ) SB = T A SB modp. AmdB can then use this shared secret key to encrypt 
subsequent communications. 

However, the Diffie-Hellman technique does not solve the authentication 
problem for an active attacker, because an active attacker can intercept 
communications from the remote user in order to impersonate the firewall. In this 
way, the active attacker will establish shared secrets with each end. Hence, even 
if the remote user encrypts its identifier with what it thinks is the shared secret key 
with the other end, the attacker is able to decrypt this identifier. 

The Internet Engineering Task Force (IETF) has developed a standard to 
facilitate using pre-shared secret keys, (see http — www.ietf.cnri.reston.va.us- 
internet-drafts-draft-ietf-ipsec-ike-base-mode-02.txt). The variant that uses pre- 
shared secret keys requires the Internet Protocol (IP) address of the remote user to 
be the identifier for the remote user. However, using the IP address of the remote 
user will not work if the remote user attempts to log in from a remote location 
with a different IP address. 
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Hence, what is needed is a method and an apparatus for facilitating a key 
exchange protocol that operates with a pre-shared key and that hides the identities 
of entities involved in the key exchange. 

SUMMARY 

One embodiment of the present invention provides a system that facilitates 
a key exchange that operates with a pre-shared secret key and that hides identities 
of parties involved in the key exchange. The method operates by establishing a 
negotiated secret key between a first party and a second party by performing 
communications between the first party and the second party across a network in a 
manner that does not allow an eavesdropper to determine the negotiated secret 
key. Next, the system encrypts an identifier for the first party using the negotiated 
secret key and a group secret key to form an encrypted identifier. This group 
secret key is known to members of a group, including the first party and the 
second party, but is kept secret from parties outside of the group. Next, the 
system sends the encrypted identifier from the first party across the network to the 
second party. This allows the second party to decrypt the encrypted identifier by 
using the negotiated secret key and the group secret key, so that the second party 
can use the identifier to lookup the pre-shared secret key that was previously 
established between the first party and the second party. This pre-shared secret 
key is subsequently used in forming at least one subsequent communication 
between the first party and the second party. 

In one embodiment of the present invention, establishing the negotiated 
secret key involves using the Diffie-Hellman method to establish the negotiated 
secret key. 

In one embodiment of the present invention, the second party is a firewall 
through which the first party seeks to communicate. 
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In one embodiment of the present invention, the first party is a person 
seeking to communicate through the firewall from one of a number of possible 
Internet Protocol (IP) addresses. 

In one embodiment of the present invention, the group secret key is one of 
5 a plurality of group secret keys maintained by the group. 

BRIEF DESCRIPTION OF THE FIGURES 

FIG. 1 illustrates a distributed computing system in accordance with an 
embodiment of the present invention. 

FIG. 2 is a flow chart illustrating the Diffie-Hellman method in accordance 
with an embodiment of the present invention. 

FIG. 3 illustrates how an identifier is securely transferred from a remote 
computer system to a firewall in accordance with an embodiment of the present 
invention. 

FIG. 4 A is a first portion of a flow chart of a key exchange protocol that 
operates with a pre-shared key and that hides the identities of entities involved in 
the key exchange in accordance with an embodiment of the present invention. 

FIG. 4B is a second portion of a flow chart of a key exchange protocol that 
operates with a pre-shared key and that hides the identities of entities involved in 
the key exchange in accordance with an embodiment of the present invention. 

DETAILED DESCRIPTION 

The following description is presented to enable any person skilled in the 
art to make and use the invention, and is provided in the context of a particular 
25 application and its requirements. Various modifications to the disclosed 

embodiments will be readily apparent to those skilled in the art, and the general 
principles defined herein may be applied to other embodiments and applications 
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without departing from the spirit and scope of the present invention. Thus, the 
present invention is not intended to be limited to the embodiments shown, but is 
to be accorded the widest scope consistent with the principles and features 
disclosed herein. 

5 The data structures and code described in this detailed description are 

typically stored on a computer readable storage medium, which may be any device 
or medium that can store code and/or data for use by a computer system. This 
includes, but is not limited to, magnetic and optical storage devices such as disk 
drives, magnetic tape, CDs (compact discs) and DVDs (digital versatile discs or 
10 digital video discs), and computer instruction signals embodied in a transmission 
medium (with or without a carrier wave upon which the signals are modulated). 
For example, the transmission medium may include a communications network, 
such as the Internet. 

15 Distributed Computing System 

FIG. 1 illustrates a distributed computing system 100 in accordance with 
an embodiment of the present invention. Distributed computing system 100 
includes a portable computer system 104, which is coupled to a network 108 
through communication channel 106 and Internet Service provider (ISP) 107. 
20 Distributed computing system 100 also includes computer systems 1 14 and 1 16 
residing on protected network 112, which are coupled to network 108 through 
firewall 110. 

Network 108 can generally include any type of wire or wireless 
communication channel capable of coupling together computing nodes. This 
25 includes, but is not limited to, a local area network, a wide area network, or a 
combination of networks. In one embodiment of the present invention, network 
108 includes the Internet. 
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Similarly, protected network 1 12 can generally include any type of wire or 
wireless communication channel capable of coupling together computing nodes 
that is protected from a public network. This includes, but is not limited to, a 
local area network, a wide area network, or a combination of networks. 

Computer systems 104, 1 14 and 116 (and firewall 110) can generally 
include any type of computer system, including, but is not limited to, a computer 
system based on a microprocessor, a mainframe computer, a digital signal 
processor, a portable computing device, a personal organizer, a device controller, 
and a computational engine within an appliance. 

Recall that computer system 104 is coupled to network 108 through 
communication channel 106 and ISP 107. Communication channel 106 can 
include any mechanism through which computer system 104 can communicate 
with ISP 107. This includes, but not limited to, a modem connection through a 
telephone line, a digital subscriber line (DSL) connection or a cable modem 
connection. ISP 107 can include any mechanism through which computer system 
104 is able to access the network 108. 

Firewall 110 can include any mechanism that protects computer systems 
1 14 and 116 on protected network 112 from communications across network 108. 
Note that all communications between network 108 and protected network 1 12 
pass through firewall 110, which allows firewall 1 10 to screen these 
communications for security purposes. 

Also note that firewall 1 10 includes key exchange mechanism 111, which 
hides the identities of parties involved in the key exchange process in accordance 
with an embodiment of the present invention. 

The system illustrated in FIG. 1 operates generally as follows. User 102 
operating computer system 104 seeks to access computer systems 1 14 and 1 16 
located on protected network 112. In order to do so, computer system 104 
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communicates with key exchange mechanism 1 1 1 within firewall 1 10 to set up an 
encrypted communication pathway between computer system 104 and firewall 
110 using a pre-shared secret key 314 (see FIG. 3). Key exchange mechanism 1 1 1 
sets up this communication pathway without divulging the identity of user 1 02 (or 
computer system 104) to an active or passive attacker. This process is described 
in more detail below with reference to FIGs. 3 and 4. 

Note that although the present invention is described in the context of a 
portable computer system 104 that communicates with a firewall 1 10, the present 
invention can generally be applied to establishing a secure communication 
pathway between any two entities, and is not limited to a portable computer 
system 104 or a firewall 110. 

Key Exchange Protocol 

FIG. 3 illustrates how an identifier (ID) 302 is securely transferred from 
remote computer system 104 to firewall 1 10 in accordance with an embodiment of 
the present invention. Note that ID 302 can include an identifier for user 102 
and/or identifier for computer system 104. 

Computer system 104 and firewall 1 10 first perform a Diffie-Hellman 
exchange to agree upon a negotiated secret key 304. 

Next, computer system 104 encrypts ID 302 using both negotiated secret 
key 304 and group secret key 306 to form encrypted ID 308. Note that any type of 
symmetric encryption mechanism or algorithm can be used to perform this 
encryption, and any function of group secret key 306 and negotiated secret key 
304 can be used to form the key for that encryption. 

Group secret key 306 is a key that is known by the members of a group to 
which user 102 belongs. For security reasons, group secret key 306 may need to 
be periodically changed. Also note that there may exist another group secret key 
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307 within firewall 1 10. This allows different group secret keys to be used for 
different purposes. These different purposes can include: facilitating key rollover 
to periodically change keys; providing different keys for different levels of 
security; and providing different keys for different sub-organizations. Note that if 
there exist multiple group keys, a specific identifier for a group secret key must be 
communicated, or there must exist few enough group secret keys for firewall 110 
to try them all. 

Computer system 104 also forms a hash 322 of negotiated secret key 304 
and pre-shared secret key 314. 

Next, encrypted ID 308 and hash 322 are sent to firewall 110. Encrypted 
ID 308 it is decrypted using both negotiated secret key 304 and group secret key 
306 to restore ID 302. Note that by using group secret key 306, ID 302 is 
protected from an active attacker who intercepts communications from computer 
system 104 and impersonates firewall 1 10 in performing the Diffie-Hellman 
exchange to obtain negotiated secret key 304. 

Next, ID 302 is used to look up pre-shared secret key 314 within a table of 
pre-shared secret keys 312. Table of pre-shared secret keys 312 can generally be 
organized as any type of lookup structure that can be used to store and retrieve 
pre-shared secret keys. 

Next, hash 122 is checked using negotiated secret key 304 and pre-shared 
secret key 314. If it is properly formed, firewall forms a hash 329 of negotiated 
secret key 304, pre-shared secret key 314 and constant 326. 

Next, hash 329 is sent to firewall 110, where it is checked using negotiated 
secret key 304, pre-shared secret key 314 and constant 326. If hash 329 is 
properly formed, communication mechanism 317 within firewall 110 then uses 
negotiated secret key 304 to encrypt communications with communication 
mechanism 316 in computer system 104. Similarly, communication mechanism 
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316 within computer system 104 uses negotiated secret key 304 to encrypt 
communications with communication mechanism 316 in firewall 110. 

Note that each user within the group has its own pre-shared secret key, 
which is stored within table of pre-shared secret keys 3 12. This prevents a given 
user within a group from impersonating another user within the group. 

FIGs. 4A and 4B present a flow chart of a key exchange protocol that 
operates with a pre-shared key and hides the identities of entities involved in the 
key exchange in accordance with an embodiment of the present invention. This 
flow chart illustrates the operations of computer system 1 04 in the left-hand 
column, and computer firewall 1 10 in the right-hand column. 

Computer system 104 and firewall 1 10 first establish a negotiated secret 
key 304 by performing a Diffie-Hellman exchange across network 108 (steps 402 
and 404). Note that in general any secure method that enables computer system 
104 and firewall 1 10 to agree upon a negotiated secret key can be used. 

Next, computer system 104 encrypts ID 302 using negotiated secret key 
304 and group secret key 306 to form encrypted ID 308 (step 406). Computer 
system 104 also forms a hash 322 of negotiated secret key 304 and pre-shared 
secret key 314 (step 407). 

Computer system 104 then sends encrypted ID 308 and hash 322 across 
network 108 to firewall 1 10 (step 408). 

Upon receiving encrypted ID 308 and hash 322 (step 410), firewall 110 
decrypts encrypted ID 308 using both negotiated secret key 304 and group secret 
key 306 to restore ID 302 (step 412). 

Next, firewall 110 uses ID 302 to lookup pre-shared secret key 314 from 
the table of pre-shared secret keys 312 (step 414). 

Firewall 1 10 than uses pre-shared secret key 3 14 and negotiated secret key 
304 to check hash 322 (step 415). If hash 322 is properly formed, firewall 110 
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forms a hash 329 of negotiated secret key 304, pre-shared secret key 314 and 
constant 326. 

Next, hash 329 is sent to firewall 1 10, where it is checked using negotiated 
secret key 304, pre-shared secret key 314 and constant 326. If hash 329 is 
properly formed, communication mechanism 317 within firewall 110 
subsequently uses negotiated secret key 304 to encrypt communications with 
communication mechanism 316 in computer system 104. Similarly, 
communication mechanism 316 within computer system 104 subsequently uses 
negotiated secret key 304 to encrypt communications with communication 
mechanism 3 16 in firewall 1 10. 

The foregoing descriptions of embodiments of the invention have been 
presented for purposes of illustration and description only. They are not intended 
to be exhaustive or to limit the present invention to the forms disclosed. 
Accordingly, many modifications and variations will be apparent to practitioners 
skilled in the art. Additionally, the above disclosure is not intended to limit the 
present invention. The scope of the present invention is defined by the appended 
claims. 
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What Is Claimed Is: 



1 LA method for facilitating a key exchange that operates with a pre- 

2 shared secret key and that hides identities of parties involved in the key exchange, 

3 comprising: 

4 encrypting an identifier for the first party using a first key that is a function 

5 of a group secret key to form an encrypted identifier; 

6 wherein the group secret key is known to members of a group, including 

7 the first party and the second party, but is kept secret from parties outside of the 

8 group; 

9 sending the encrypted identifier from the first party across the network to 

10 the second party; 

1 1 allowing the second party to decrypt the encrypted identifier by using the 

12 group secret key; 

13 allowing the second party to use the identifier to lookup the pre-shared 

14 secret key that was previously established between the first party and the second 

15 party; and 

16 using the pre-shared secret key in forming at least one subsequent 

1 7 communication between the first party and the second party. 

1 2. The method of claim 1, further comprising initially establishing a 

2 negotiated secret key between a first party and a second party by performing 

3 communications between the first party and the second party across a network; 

4 wherein the communications between the first party and the second party 

5 do not allow an eavesdropper to determine the negotiated secret key; 

6 wherein the first key is additionally a function of the negotiated secret key; 

7 and 

12 

Attorney Docket No. SUN-P50 1 2-RSH Inventor(s): Radia J. Perlman 

ARP\\PORSCHE\MY DOCUMENTS\SUN MICROS YSTEMS\SWSf-P50 1 2-RSH\SUN-P50 1 2-RSH APPLICATION DOC 



I 



8 wherein decrypting the encrypted identifier additionally involves using the 

9 negotiated secret key. 

1 3. The method of claim 2, wherein establishing the negotiated secret 

2 key involves using the Diffie-Hellman method to establish the negotiated secret 

3 key. 

1 4. The method of claim 1, wherein the second party is a firewall 

2 through which the first party seeks to communicate. 

1 5. The method of claim 4, wherein the first party is a person seeking 

2 to communicate through the firewall from one of a number of possible Internet 

3 Protocol (IP) addresses. 

1 6. The method of claim 1 , wherein the group secret key is one of a 

2 plurality of group secret keys maintained by the group. 

1 7. A method for facilitating a key exchange that operates with a pre- 

2 shared secret key and that hides identities of parties involved in the key exchange, 

3 comprising: 

4 allowing the first party to encrypt an identifier for the first using a first key 

5 that is a function of a group secret key to form an encrypted identifier; 

6 wherein the group secret key is known to members of a group, including 

7 the first party and the second party, but is kept secret from parties outside of the 

8 group; 

9 receiving the encrypted identifier at the second party from the first party 

10 across the network; 
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1 1 decrypting the encrypted identifier by using the group secret key; 

12 using the identifier to lookup the pre-shared secret key that was previously 

1 3 established between the first party and the second party; and 

14 using the pre-shared secret key in forming at least one subsequent 

15 communication between the first party and the second party. 

1 8. The method of claim 7, further comprising initially establishing a 

2 negotiated secret key between a first party and a second party by performing 

3 communications between the first party and the second party across a network; 

4 wherein the communications between the first party and the second party 

5 do not allow an eavesdropper to determine the negotiated secret key; 

6 wherein the first key is additionally a function of the negotiated secret key; 

7 and 

8 wherein decrypting the encrypted identifier additionally involves using the 

9 negotiated secret key. 

1 9. The method of claim 8, wherein establishing the negotiated secret 

2 key involves using the Diffie-Hellman method to establish the negotiated secret 

3 key. 

1 10. The method of claim 7, wherein the second party is a firewall 

2 through which the first party seeks to communicate. 

1 11. The method of claim 1 0, wherein the first party is a person seeking 

2 to communicate through the firewall from one of a number of possible Internet 

3 Protocol (IP) addresses. 
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1 12. The method of claim 7, wherein the group secret key is one of a 

2 plurality of group secret keys maintained by the group. 

1 1 3 . A computer-readable storage medium storing instructions that 

2 when executed by a computer cause the computer to perform a method for 

3 facilitating a key exchange that operates with a pre-shared secret key and that 

4 hides identities of parties involved in the key exchange, the method comprising: 

5 encrypting an identifier for the first party using a first key that is a function 

6 of a group secret key to form an encrypted identifier; 

7 wherein the group secret key is known to members of a group, including 

8 the first party and the second party, but is kept secret from parties outside of the 

9 group; 

10 sending the encrypted identifier from the first party across the network to 

1 1 the second party; 

12 allowing the second party to decrypt the encrypted identifier by using the 

13 group secret key; 

14 allowing the second party to use the identifier to lookup the pre-shared 

1 5 secret key that was previously established between the first party and the second 

16 party; and 

17 using the pre-shared secret key in forming at least one subsequent 

1 8 communication between the first party and the second party. 

1 14. The computer-readable storage medium of claim 13, wherein the 

2 method further comprises initially establishing a negotiated secret key between a 

3 first party and a second party by performing communications between the first 

4 party and the second party across a network; 
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5 wherein the communications between the first party and the second party 

6 do not allow an eavesdropper to determine the negotiated secret key; 

7 wherein the first key is additionally a function of the negotiated secret key; 

8 and 

9 wherein decrypting the encrypted identifier additionally involves using the 
1 0 negotiated secret key. 

1 15. The computer-readable storage medium of claim 1 4, wherein 

2 establishing the negotiated secret key involves using the Diffie-Hellman method 

3 to establish the negotiated secret key. 

1 1 6. The computer-readable storage medium of claim 13, wherein the 

2 second party is a firewall through which the first party seeks to communicate. 

1 17. The computer-readable storage medium of claim 1 6, wherein the 

2 first party is a person seeking to communicate through the firewall from one of a 

3 number of possible Internet Protocol (IP) addresses. 

1 18. The computer-readable storage medium of claim 1 3 , wherein the 

2 group secret key is one of a plurality of group secret keys maintained by the 

3 group. 

1 19. A computer-readable storage medium storing instructions that 

2 when executed by a computer cause the computer to perform a method for 

3 facilitating a key exchange that operates with a pre-shared secret key and that 

4 hides identities of parties involved in the key exchange, the method comprising: 
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5 allowing the first party to encrypt an identifier for the first party using a 

6 first key that is a function of a group secret key to form an encrypted identifier; 

7 wherein the group secret key is known to members of a group, including 

8 the first party and the second party, but is kept secret from parties outside of the 

9 group; 

1 0 receiving the encrypted identifier at the second party from the first party 

1 1 across the network; 

12 decrypting the encrypted identifier by using the group secret key; 

1 3 using the identifier to lookup the pre-shared secret key that was previously 

14 established between the first party and the second party; and 

1 5 using the pre-shared secret key in forming at least one subsequent 

1 6 communication between the first party and the second party. 

1 20. An apparatus that facilitates a key exchange that operates with a 

2 pre-shared secret key and that hides identities of parties involved in the key 

3 exchange, the apparatus comprising: 

4 an encryption mechanism that is configured to encrypt an identifier for the 

5 first party using a first key that is a function of a group secret key to form an 

6 encrypted identifier; 

7 wherein the group secret key is known to members of a group, including 

8 the first party and the second party, but is kept secret from parties outside of the 

9 group; 

1 0 a communication mechanism that is configured to send the encrypted 



1 1 identifier from the first party across the network to the second party, so that the 

12 second party can decrypt the encrypted identifier by using the group secret key in 

1 3 order to use the identifier to lookup the pre-shared secret key that was previously 

14 established between the first party and the second party; and 
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1 5 wherein the communication mechanism is additionally configured to use 

1 6 the pre-shared secret key to encrypt at least one subsequent communication 

1 7 between the first party and the second party. 

1 21. The apparatus of claim 20, further comprising a negotiation 

2 mechanism that is configured to establish a negotiated secret key between a first 

3 party and a second party by performing communications between the first party 

4 and the second party across a network; 

5 wherein the communications between the first party and the second party 

6 do not allow an eavesdropper to determine the negotiated secret key; and 

7 wherein the first key is additionally a function of the negotiated secret key; 

8 and 

9 wherein decrypting the encrypted identifier additionally involves using the 
1 0 negotiated secret key. 

1 22. The apparatus of claim 2 1 , wherein establishing the negotiated 

2 secret key involves using the Diffie-Hellman method to establish the negotiated 

3 secret key. 

1 23 . The apparatus of claim 20, wherein the second party is a firewall 

2 through which the first party seeks to communicate. 

1 24. The apparatus of claim 23 , wherein the first party is a person 

2 seeking to communicate through the firewall from one of a number of possible 

3 Internet Protocol (IP) addresses. 
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1 25. The apparatus of claim 20, wherein the group secret key is one of a 

2 plurality of group secret keys maintained by the group. 

1 26. An apparatus that facilitates a key exchange that operates with a 

2 pre-shared secret key and that hides identities of parties involved in the key 

3 exchange, the apparatus comprising: 

4 a communication mechanism that is configured to receive an encrypted 

5 identifier at the second party from the first party across the network; 

6 wherein the encrypted identifier was produced by encrypting an identifier 

7 for the first party using a first key that is a function of a group secret key; 

8 wherein the group secret key is known to members of a group, including 

9 the first party and the second party, but is kept secret from parties outside of the 

10 group; 

1 1 a decryption mechanism that is configured to decrypt the encrypted 

1 2 identifier by using the group secret key; 

1 3 a lookup mechanism that is configured to use the identifier to lookup the 

14 pre-shared secret key that was previously established between the first party and 

1 5 the second party; and 

1 6 wherein the communication mechanism is additionally configured to use 

1 7 the pre-shared secret key in forming at least one subsequent communication 

1 8 between the first party and the second party. 
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METHOD AND APPARATUS FOR 
FACILITATING USE OF A PRE-SHARED 
SECRET KEY WITH IDENTITY HIDING 



ABSTRACT 

One embodiment of the present invention provides a system that facilitates 
a key exchange that operates with a pre-shared secret key and that hides identities 
of parties involved in the key exchange. The method operates by establishing a 
negotiated secret key between a first party and a second party by performing 
communications between the first party and the second party across a network in a 
manner that does not allow an eavesdropper to determine the negotiated secret 
key. Next, the system encrypts an identifier for the first party using the negotiated 
secret key and a group secret key to form an encrypted identifier. This group 
secret key is known to members of a group, including the first party and the 
second party, but is kept secret from parties outside of the group. Next, the 
system sends the encrypted identifier from the first party across the network to the 
second party. This allows the second party to decrypt the encrypted identifier by 
using the negotiated secret key and the group secret key, so that the second party 
can use the identifier to lookup the pre-shared secret key that was previously 
established between the first party and the second party. This pre-shared secret 
key is subsequently used in forming at least one subsequent communication 
between the first party and the second party. 
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